<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8" />
    <meta http-equiv="X-UA-Compatible" content="IE=edge" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <title>defineProperty</title>
  </head>
  <body>
    <!-- 这块式ES6中的内容 -->
    <script>
      let number = 18;
      let person = {
        name: "张三",
        sex: "男",
      };

      Object.defineProperty(person, "age", {
        // value: 18,
        // enumerable: true,//控制属性是否可以枚举，默认是false
        // writable:true,//控制属性是否可修改，默认值式false
        // configurable:true//控制属性是否可以删除，默认值是false

        //当有人读取person的age属性时，get函数(getter)就会被调用 且返回值就是age的值
        get() {
          console.log("有人读取age属性了");
          return number;
        },
        //当有人修改person的age属性时，set函数（setter）就会被调用，且会收到修改的具体值
        set(value) {
          console.log("有人修改了age属性且值是", value);
          number = value;
        },
      });

      //   console.log(Object.keys(person));

      for (let key in person) {
        console.log("@", person[key]);
      }
      console.log(person);
    </script>
  </body>
</html>
